home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1996 June / EnigmA AMIGA RUN 08 (1996)(G.R. Edizioni)(IT)[!][issue 1996-06][EARSAN CD VII].iso / earcd / comm1 / intsdkss.lha / include / netinet / ip.h < prev    next >
C/C++ Source or Header  |  1996-04-09  |  5KB  |  141 lines

  1. /*
  2.  * Copyright (c) 1982, 1986 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms are permitted
  6.  * provided that the above copyright notice and this paragraph are
  7.  * duplicated in all such forms and that any documentation,
  8.  * advertising materials, and other materials related to such
  9.  * distribution and use acknowledge that the software was developed
  10.  * by the University of California, Berkeley.  The name of the
  11.  * University may not be used to endorse or promote products derived
  12.  * from this software without specific prior written permission.
  13.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
  14.  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
  15.  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  16.  *
  17.  *    @(#)ip.h        7.6.1.3 (Berkeley) 2/20/89
  18.  */
  19. #ifndef BYTE_ORDER
  20. /*
  21.  * Definitions for byte order,
  22.  * according to byte significance from low address to high.
  23.  */
  24. #define LITTLE_ENDIAN    1234    /* least-significant byte first (vax) */
  25. #define BIG_ENDIAN    4321    /* most-significant byte first (IBM, net) */
  26. #define PDP_ENDIAN    3412    /* LSB first in word, MSW first in long (pdp) */
  27.  
  28. #ifdef vax
  29. #define BYTE_ORDER    LITTLE_ENDIAN
  30. #else
  31. #define BYTE_ORDER    BIG_ENDIAN    /* mc68000, tahoe, most others */
  32. #endif
  33. #endif /* BYTE_ORDER */
  34.  
  35. /*
  36.  * Definitions for internet protocol version 4.
  37.  * Per RFC 791, September 1981.
  38.  */
  39. #define IPVERSION    4
  40.  
  41. /*
  42.  * Structure of an internet header, naked of options.
  43.  *
  44.  * We declare ip_len and ip_off to be short, rather than u_short
  45.  * pragmatically since otherwise unsigned comparisons can result
  46.  * against negative integers quite easily, and fail in subtle ways.
  47.  */
  48. struct ip {
  49.     u_int    ip_v:4;         /* version */
  50.     u_int    ip_hl:4;        /* header length */
  51.     u_int    ip_tos:8;        /* type of service */
  52.     u_int    ip_len:16;        /* length */
  53.     u_short ip_id;            /* identification */
  54.     short    ip_off;         /* fragment offset field */
  55. #define IP_DF 0x4000            /* dont fragment flag */
  56. #define IP_MF 0x2000            /* more fragments flag */
  57.     u_char    ip_ttl;         /* time to live */
  58.     u_char    ip_p;            /* protocol */
  59.     u_short ip_sum;         /* checksum */
  60.     struct    in_addr ip_src,ip_dst;    /* source and dest address */
  61. };
  62.  
  63. #define IP_MAXPACKET    65535        /* maximum packet size */
  64.  
  65. /*
  66.  * Definitions for options.
  67.  */
  68. #define IPOPT_COPIED(o)         ((o)&0x80)
  69. #define IPOPT_CLASS(o)          ((o)&0x60)
  70. #define IPOPT_NUMBER(o)         ((o)&0x1f)
  71.  
  72. #define IPOPT_CONTROL        0x00
  73. #define IPOPT_RESERVED1     0x20
  74. #define IPOPT_DEBMEAS        0x40
  75. #define IPOPT_RESERVED2     0x60
  76.  
  77. #define IPOPT_EOL        0        /* end of option list */
  78. #define IPOPT_NOP        1        /* no operation */
  79.  
  80. #define IPOPT_RR        7        /* record packet route */
  81. #define IPOPT_TS        68        /* timestamp */
  82. #define IPOPT_SECURITY        130        /* provide s,c,h,tcc */
  83. #define IPOPT_LSRR        131        /* loose source route */
  84. #define IPOPT_SATID        136        /* satnet id */
  85. #define IPOPT_SSRR        137        /* strict source route */
  86.  
  87. /*
  88.  * Offsets to fields in options other than EOL and NOP.
  89.  */
  90. #define IPOPT_OPTVAL        0        /* option ID */
  91. #define IPOPT_OLEN        1        /* option length */
  92. #define IPOPT_OFFSET        2        /* offset within option */
  93. #define IPOPT_MINOFF        4        /* min value of above */
  94.  
  95. /*
  96.  * Time stamp option structure.
  97.  */
  98. struct    ip_timestamp {
  99.     u_char    ipt_code;        /* IPOPT_TS */
  100.     u_char    ipt_len;        /* size of structure (variable) */
  101.     u_char    ipt_ptr;        /* index of current entry */
  102. #if BYTE_ORDER == LITTLE_ENDIAN
  103.     u_int    ipt_flg:4,        /* flags, see below */
  104.         ipt_oflw:4;        /* overflow counter */
  105. #endif
  106. #if BYTE_ORDER == BIG_ENDIAN
  107.     u_int    ipt_oflw:4,        /* overflow counter */
  108.         ipt_flg:4;        /* flags, see below */
  109. #endif
  110.     union ipt_timestamp {
  111.         u_long    ipt_time[1];
  112.         struct    ipt_ta {
  113.             struct in_addr ipt_addr;
  114.             u_long ipt_time;
  115.         } ipt_ta[1];
  116.     } ipt_timestamp;
  117. };
  118.  
  119. /* flag bits for ipt_flg */
  120. #define IPOPT_TS_TSONLY     0        /* timestamps only */
  121. #define IPOPT_TS_TSANDADDR    1        /* timestamps and addresses */
  122. #define IPOPT_TS_PRESPEC    3        /* specified modules only */
  123.  
  124. /* bits for security (not byte swapped) */
  125. #define IPOPT_SECUR_UNCLASS    0x0000
  126. #define IPOPT_SECUR_CONFID    0xf135
  127. #define IPOPT_SECUR_EFTO    0x789a
  128. #define IPOPT_SECUR_MMMM    0xbc4d
  129. #define IPOPT_SECUR_RESTR    0xaf13
  130. #define IPOPT_SECUR_SECRET    0xd788
  131. #define IPOPT_SECUR_TOPSECRET    0x6bc5
  132.  
  133. /*
  134.  * Internet implementation parameters.
  135.  */
  136. #define MAXTTL        255        /* maximum time to live (seconds) */
  137. #define IPFRAGTTL    60        /* time to live for frags, slowhz */
  138. #define IPTTLDEC    1        /* subtracted when forwarding */
  139.  
  140. #define IP_MSS        576        /* default maximum segment size */
  141.